



## FIGURE 1



FIGURE 2

SELECTABLE VOLTAGE  
E.G. 2.5V V<sub>DD</sub>  
DIGITAL SUPPLY PIN



FIGURE 3



FIGURE 4



## FIGURE 5

## 2. Bismarck Since Decimation Chain



## FIGURE 6

- Fifth order decimate by 8:

$$H(z) = \left( \frac{1-z^{-4}}{1-z^{-1}} \right)^5$$

- 36 tap FIR filter. Half of the (symmetric) coefficients

|           |              |               |               |               |               |               |               |               |
|-----------|--------------|---------------|---------------|---------------|---------------|---------------|---------------|---------------|
| $h_0=1$   | $h_1=5$      | $h_2=15$      | $h_3=35$      | $h_4=70$      | $h_5=126$     | $h_6=210$     | $h_7=330$     | $h_8=490$     |
| $h_9=690$ | $h_{10}=926$ | $h_{11}=1190$ | $h_{12}=1470$ | $h_{13}=1750$ | $h_{14}=2010$ | $h_{15}=2226$ | $h_{16}=2380$ | $h_{17}=2460$ |

FIGURE 7



FIGURE 8

Figure 9

### Impulse Response:

$$y[n] = x[n] + 6 \cdot x[n-1] + 15 \cdot x[n-2] + 20 \cdot x[n-3] + 15 \cdot x[n-4] + 6 \cdot x[n-5] + x[n-6]$$

$$H(z) = \left( \frac{1 - z^{-2}}{1 - z^{-1}} \right)^6$$

### 3. Bismarck Sinc1b Functional Diagram



FIGURE 10

| Filter Name | System Function                                   | IMPULSE RESPONSE (FILTER COEFFICIENTS)            |
|-------------|---------------------------------------------------|---------------------------------------------------|
| Sinc2(a)    | $H(z) = \left(\frac{1-z^{-2}}{1-z^{-1}}\right)^4$ | $h[n] = [1 \ 4 \ 6 \ 4 \ 1]$                      |
| Sinc2(b)    | $H(z) = \left(\frac{1-z^{-3}}{1-z^{-1}}\right)^4$ | $h[n] = [1 \ 4 \ 10 \ 16 \ 19 \ 16 \ 10 \ 4 \ 1]$ |
| Sinc2(c)    | $H(z) = \left(\frac{1-z^{-3}}{1-z^{-1}}\right)^5$ | $h[n] = [1 \ 4 \ 10 \ 16 \ 19 \ 16 \ 10 \ 4 \ 1]$ |
| Sinc2(d)    | $H(z) = \left(\frac{1-z^{-2}}{1-z^{-1}}\right)^5$ | $h[n] = [1 \ 5 \ 10 \ 10 \ 5 \ 1]$                |
| Sinc2(e)    | $H(z) = \left(\frac{1-z^{-2}}{1-z^{-1}}\right)^6$ | $h[n] = [1 \ 6 \ 15 \ 20 \ 15 \ 6 \ 1]$           |

Figure 11

### Sinc2(a) and Sinc2(b):

$$\begin{aligned} y[n] &= x[n] + 4x[n-1] + 6x[n-2] & + 4x[n-3] + x[n-4] \\ &= x[n] + 4x[n-1] + 4x[n-2] + 2x[n-3] & + 4x[n-3] + x[n-4] \end{aligned}$$



Figure 12

Figure 13A Sinc2(c):

$$\begin{aligned}
 y[n] &= x[n] + 4x[n-1] + 10x[n-2] + 16x[n-3] + 19x[n-4] + 16x[n-5] + 10x[n-6] + 4x[n-7] + x[n-8] \\
 &= x[n] + 4x[n-1] + [8x[n-2] + 2x[n-1]] + 16x[n-3] + [16x[n-4] + 2x[n-4]] + x[n-4] \\
 &\quad + 16x[n-5] + [8x[n-6] + 2x[n-6]] + 4x[n-7] + x[n-8]
 \end{aligned}$$

Figure 13B Sinc2(d):

$$\begin{aligned}
 y[n] &= x[n] + 5x[n-1] + 10x[n-2] + 10x[n-3] + 5x[n-4] + x[n-5] \\
 &= x[n] + [4x[n-1] + x[n-1]] + [8x[n-2] + 2x[n-2]] + [8x[n-3] + 2x[n-3]] + [4x[n-4] + x[n-4]] + x[n-5]
 \end{aligned}$$

Figure 13C Sinc2(e):

$$\begin{aligned}
 y[n] &= x[n] + 6x[n-1] + 15x[n-2] + 20x[n-3] + 15x[n-4] + 6x[n-5] + x[n-6] \\
 &= x[n] + [4x[n-1] + 2x[n-1]] + [16x[n-2] - x[n-2]] + [16x[n-3] + 4x[n-3]] \\
 &\quad + [16x[n-4] - x[n-4]] + [4x[n-5] + 2x[n-5]] + x[n-6]
 \end{aligned}$$

**Sinc2(a) and Sinc2(b):**



Accumulate Phase (2 additions)  
 $F_{16 \times 4} / 4A$

Output Phase (4 additions)  
 $F_{16 \times 4} / 4B$

**Sinc2(d):**



Accumulate Phase (5 additions)



Output Phase (5 additions)

$F_{16 \times 4} / 5A$

$F_{16 \times 4} / 5B$

Sinc2(c):



FIGURE 16A

Accumulate Phase B (5 additions)

FIGURE 16B

Accumulate Phase A (4 additions)



Output Phase (4 additions)

FIGURE 16C

Sinc2(e):



Accumulate Phase (6 additions)  
FIGURE 17A



FIGURE 17B

Figure 18A

CLK64



Figure 18B

2aA(2)



Figure 18C

2aO(4)



Figure 18D

2bA(2)



Figure 18E

2bO(4)



Figure 18F

2dA(5)



Figure 18G

2dO(5)



Figure 18H

2eA(6)



Figure 18I

2eO(6)



RAM1  
Main Program



RAM2  
Subroutines



Figure 19A

Figure 19B

## Sinc2 Control-Datapath Architecture



Figure 20A



FIGURE 20B

### Programming Procedure:

1. Select decimation rate.
2. Select required mini-sincs and associated Accumulate and Output subroutines.
3. Separate coefficients into form suitable for shift-add operations.
4. Check for overflow after each addition in the filter.
5. Perform necessary truncation to 24 bits and scaling of subsequent coefficients in mini-sincs.
6. Time multiplex Accumulate and Output Subroutines so that a maximum of 8 additions/subtractions are performed for each input from sinc1.
7. Create code for RAM2 (Accumulate and Output Subroutines) in the form:  
[Coeff 1] [Src 1] [Src 2] [Dest] [Coeff2] [Done Subroutine]
8. Create code for RAM1 (Main Control code)  
[Line #] [Wait for new data] [Done program]

FIGURE 21



FIGURE 22



FIGURE 23

DSP Program Memory Map



DSP Data Memory/Register Map



FIGURE 24A

FIGURE 24B



FIGURE 25



FIGURE 26



FIGURE 27



FIGURE 28



FIGURE 29



FIGURE 30A



FIGURE 30B

FIGURE 30C1

— wire

FIGURE 30C2

—  
24 wires

FIGURE 30C3

[ ] register

FIGURE 30C4

△ multiplexer

FIGURE 30C5

△ tristate buffer

FIGURE 30C6

△ inverter

FIGURE 30C7

○○ exclusive or gate

FIGURE 30C8

△ + adder

FIGURE 30C9

△ \* multiplier

FIGURE 30C10

[ ] right shifter



FIGURE 30F1

| State | Actions During State                        |                                 |              |
|-------|---------------------------------------------|---------------------------------|--------------|
| S0    | $D_0(D4_k) = D_4(D4_{k-1}) + D_3(D3_{k-1})$ | Clear SUM                       | Load $DIN_k$ |
| S1    | $D_0(D3_k) = D_4(D3_{k-1}) + D_3(D2_{k-1})$ | $SUM_k += D_0(D4_k) \gg Shift4$ |              |
| S2    | $D_0(D2_k) = D_4(D2_{k-1}) + D_3(D1_{k-1})$ | $SUM_k += D_0(D3_k) \gg Shift3$ |              |
| S3    | $D_0(D1_k) = D_4(D1_{k-1}) + D_3(R_{k-1})$  | $SUM_k += D_0(D2_k) \gg Shift2$ |              |
| S4    |                                             | $SUM_k += D_0(D1_k) \gg Shift1$ |              |
| S5    | $D_0(R_k) = DIN_k +/- VREF$                 |                                 |              |

FIGURE 30F2



FIGURE 30 G1

| State | Actions During State                            |                                                |                              |                                 |
|-------|-------------------------------------------------|------------------------------------------------|------------------------------|---------------------------------|
| S0    | Clear SUM                                       | Clear C                                        | Clear B                      | Clear A                         |
| S1    |                                                 |                                                |                              | Load A<Mem(D4 <sub>k</sub> )    |
| S2    |                                                 |                                                | Shift B<A(D4 <sub>k</sub> )  | Load A<Mem(D3 <sub>k</sub> )    |
| S3    | SUM <sub>k</sub> += B(D4 <sub>k</sub> )>>Shift4 | C = B(D4 <sub>k</sub> ) + A(D3 <sub>k</sub> )  | Shift B<A(D3 <sub>k</sub> )  | Load A<Mem(D2 <sub>k</sub> )    |
| S4    |                                                 |                                                |                              | Store C>Mem(D4 <sub>k+1</sub> ) |
| S5    | SUM <sub>k</sub> += B(D3 <sub>k</sub> )>>Shift3 | C = B(D3 <sub>k</sub> ) + A(D2 <sub>k</sub> )  | Shift B<A(D2 <sub>k</sub> )  | Load A<Mem(D1 <sub>k</sub> )    |
| S6    |                                                 |                                                |                              | Store C>Mem(D3 <sub>k+1</sub> ) |
| S7    | SUM <sub>k</sub> += B(D2 <sub>k</sub> )>>Shift2 | C = B(D2 <sub>k</sub> ) + A(D1 <sub>k</sub> )  | Shift B<A(D1 <sub>k</sub> )  | Load A<Mem(DIN <sub>k</sub> )   |
| S8    |                                                 |                                                |                              | Store C>Mem(D2 <sub>k+1</sub> ) |
| S9    | SUM <sub>k</sub> += B(D1 <sub>k</sub> )>>Shift1 | C = B(D1 <sub>k</sub> ) + A(DIN <sub>k</sub> ) | Shift B<A(DIN <sub>k</sub> ) | Load A<Mem(VREF)                |
| S10   |                                                 |                                                | Shift B<A(VREF)              | LoadReg A<C(Temp)               |
| S11   |                                                 | C = +/-B(VREF) + A(Temp)                       |                              |                                 |
| S12   |                                                 |                                                |                              | Store C>Mem(D1 <sub>k+1</sub> ) |

FIGURE 30 G2



FIGURE 30 H1

| State | Actions During State                            |                                                  |                                                           |                       |
|-------|-------------------------------------------------|--------------------------------------------------|-----------------------------------------------------------|-----------------------|
| S0    | Clear SUM                                       | Load C < D4 <sub>k</sub>                         |                                                           | Load DIN <sub>k</sub> |
| S1    | SUM <sub>k</sub> += C(D4 <sub>k</sub> )>>Shift4 | Load C < D3 <sub>k</sub>                         | D4 <sub>k+1</sub> = C(D4 <sub>k</sub> ) + D3 <sub>k</sub> |                       |
| S2    | SUM <sub>k</sub> += C(D3 <sub>k</sub> )>>Shift3 | Load C < D2 <sub>k</sub>                         | D3 <sub>k+1</sub> = C(D3 <sub>k</sub> ) + D2 <sub>k</sub> |                       |
| S3    | SUM <sub>k</sub> += C(D2 <sub>k</sub> )>>Shift2 | Load C < D1 <sub>k</sub>                         | D2 <sub>k+1</sub> = C(D2 <sub>k</sub> ) + D1 <sub>k</sub> |                       |
| S4    | SUM <sub>k</sub> += C(D1 <sub>k</sub> )>>Shift1 | C(Temp) = C(D1 <sub>k</sub> ) + DIN <sub>k</sub> |                                                           |                       |
| S5    |                                                 |                                                  | D1 <sub>k+1</sub> = C(Temp) +/- VREF                      |                       |

FIGURE 30 H2



FIGURE 31



FIGURE 32

| P | Feedforward                                                                                                      | Integration                     | Temp | Din                   | SUM       | SUMSIGN | TEMP | S Bus                       | I Bus | Write I |
|---|------------------------------------------------------------------------------------------------------------------|---------------------------------|------|-----------------------|-----------|---------|------|-----------------------------|-------|---------|
| 0 | $SUM_k = D4_{k>>11} + D4_{k>>9} + D4_{k>>7}$                                                                     | $D4_{k+1} = D4_k + D3_k$        |      | Load DIN <sub>k</sub> | Write     |         |      | +D4>>7<br>+D4>>9<br>+D4>>11 | +D3   | D4      |
| 1 | $SUM_k = SUM_k + D3_k$<br>+ D3 <sub>k&gt;&gt;8</sub><br>+ D3 <sub>k&gt;&gt;5</sub><br>+ D3 <sub>k&gt;&gt;4</sub> | $D3_{k+1} = D3_k + D2_k$        |      |                       | Acc/Write |         |      | +D3>>4<br>+D3>>5<br>+D3>>8  | +D2   | D3      |
| 2 | $SUM_k = SUM_k + D2_k$<br>+ D2 <sub>k&gt;&gt;1</sub><br>- D2 <sub>k&gt;&gt;7</sub><br>- D2 <sub>k&gt;&gt;4</sub> | $D2_{k+1} = D2_k + D1_k$        |      |                       | Acc/Write |         |      | -D2>>4<br>+D2>>1<br>-D2>>7  | +D1   | D2      |
| 3 | $SUM_k = SUM_k + D1_k$                                                                                           | $D1_{k+1}' = D1_k + DIN_k$      |      |                       | Acc/Write |         |      | +D1                         | +DIN  | D1      |
| 4 |                                                                                                                  | $D1_{k+1} = D1_{k+1}' +/- VREF$ |      |                       |           |         |      | -D1                         | +DI   |         |
| 5 |                                                                                                                  |                                 |      |                       |           |         |      |                             | +FB   | D1      |
| 6 |                                                                                                                  |                                 |      |                       |           |         |      |                             |       |         |
| 7 |                                                                                                                  |                                 |      |                       |           |         |      |                             |       |         |

Figure 33

FIGURE 34



FIGURE 35A

Table 1: Legend

|                   |                                                              |
|-------------------|--------------------------------------------------------------|
| <i>dout_dly0</i>  | data output bit, 0 delay                                     |
| <i>dout</i>       | data output bit, 0-63 clock delay                            |
| <i>delay[5:0]</i> | how many clocks (0-63) to delay output data <i>dout_dly0</i> |
| <i>delay[5:4]</i> | selects segment into which to direct <i>dout_dly0</i>        |
| <i>delay[3:0]</i> | selects where to tap segment D to get <i>dout</i>            |

FIGURE 35B

FIGURE 36

RSU & ADC Interface Clock Relationships with SYNC

RSU Clocks (Created from CLK16 Rising Edge)



ADC Clocks (created from CLK16 Falling Edge)





Figure 37